初始化云盘时,在CentOS 7系统mount本地盘时出现命令卡住现象,如何处理?

本文介绍初始化云盘时,在CentOS 7系统mount本地盘时出现命令卡住现象的问题描述、问题原因和解决方案。

问题描述

CentOS 7系统使用ext4文件系统批量初始化本地盘时,使用mount命令挂载本地盘时出现命令卡住的现象,然后使用ps命令查看mount进程为D状态(睡眠状态)。

问题原因

该问题是由于Linux2.6.37及更高的内核版本(通过uname -r查询)默认启用了lazy init功能导致。CentOS 7系统的内核版本是3.10,因此默认启用了lazy init功能。

使用ext4文件系统首次执行mount操作时需要初始化inode table。但是CentOS 7默认启用了lazy init功能,导致在初始化ext4文件系统时不会立刻去初始化文件系统的inode table,而是在mount挂载云盘时才进行。同时在3.10内核中mount时会有获取IO锁的操作,本地盘规格族由于容量较大,系统需要随机在云盘中写入数据,初始化需要的时间长,会出现mount需要的IO锁被lazy init长时间占用的情况,因此导致mount命令卡住。

说明
  • 4.x版本内核中,对锁机制进行了优化,因此没有这个问题。

  • 关于本地盘的更多信息,请参见本地盘

解决方案

方案一:关闭lazy init功能

在云盘初始化时执行以下命令,关闭lazy init功能。

mkfs.ext4 -E lazy_itable_init=0,lazy_journal_init=0

此方案在数据盘容量较大时,初始化也比较耗费。例如32ecs.d3s.16xlarge规格的本地盘全部初始化挂载完成约耗时4.5~5小时。

云盘初始化的更多信息,请参见初始化概述

方案二:使用xfs初始化

CentOS 7系统默认使用ext4文件系统,建议您使用xfs文件系统对云盘初始化。云盘初始化的更多信息,请参见初始化概述

xfs文件系统的初始化策略是按需分配,因此没有ext4文件系统全盘初始化的操作, 此方案对数据盘进行初始化时挂载速度较快。例如32ecs.d3s.16xlarge规格的本地盘全部初始化挂载完成仅需几分钟。

重要

CentOS 7系统默认使用ext4文件系统,建议您在环境上使用xfs文件系统时进行测试验证后再进行业务操作,避免出现兼容性问题。